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Рассматривается задача построения автономным мобильным роботом топологической модели своей опера- 
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Введение 


Актуальными проблемами в области разработки информационного обеспечения 
мобильных роботов являются проблемы представления операционной среды и раз- 
работка методов навигации в этой среде [1]. К моделированию таких сред определилось 
два подхода: метрический, использующий геометрические свойства среды, и топологи- 
ческий, использующий описания связей между различными областями среды [2]. Топо- 
логические модели представляют собой ориентированные или неориентированные 
графы с размеченными различными способами вершинами и/или дугами. Такой подход 
позволяет применять для решения конкретных задач навигации широкий набор эффек- 
тивных алгоритмов теории графов [3]. 

В данной работе под навигацией понимается перемещение мобильного агента 
(робота, поисковой программы и т.п.) из текущей области его операционной среды в 
заданную ее область. Полагаем, что в решении задач навигации участвует коллектив, 
состоящий из агента-супервизора (АС) и транспортного агента (АТ). АС выраба- 
тывает описание пути из текущего местоположения АТ в область назначения и пере- 
дает его АТ. Используя это описание, АТ самостоятельно проходит путь в среде. 

При планировании навигации возникают три взаимосвязанные фундаменталь- 
ные задачи: задача построения модели неизвестной среды (ехрогайоп), задача опре- 
деления положения робота в известной среде (тоБо{ зе{-|осайоп) и задача проверки 
соответствия неизвестной среды и ее модели (карты) (тар уаПданоп) [4]. Заметим, 
что эти задачи имеют соответствующие аналоги в теории автоматов [5]. 

В данной работе рассматривается построение коллективом агентов модели не- 
известной им среды. Коллектив состоит из агента-супервизора (АС) и агента-иссле- 
дователя (АИ). АИ перемещается по среде и воспринимает локальную информацию, 
достаточную для сопоставления областям среды элементов модели. Если восприни- 
маемой информации не достаточно для такого сопоставления, то АИ изменяет среду 
путем установки искусственных ориентиров. АИ передает информацию о среде и 
произведенных им ее изменениях АС, который и строить модель среды. По этой 
модели АС создает описания путей для АТ. 

В качестве модели рабочей среды мобильных агентов мы будем рассматривать 
конечные простые связные неориентированные графы, вершины которых могут быть 
помечены метками из некоторого множества меток (т.н. помеченные графы). Такая 
модель возникает, например, при качественной навигации мобильных роботов [6], [7]. 

Целью данной работы является разработка алгоритма построения коллекти- 
вом из АС и АИ топологической модели неизвестной ему среды в условиях, когда 
естественные (т.е. являющиеся частью среды) ориентиры недоступны АИ. В результате 
выполнения алгоритма в областях среды устанавливаются искусственные ориентиры 
так, что АТ может осуществлять навигацию по путям, описываемым цепочками этих 
ориентиров. 


Постановка задачи 


АИ установлен в произвольную вершину неизвестного ему связного простого 
неорграфа. Все вершины графа не помечены (или, что равносильно, помечены одной 
и той же меткой). АИ наблюдает 3-окрестность текущей вершины (т.е. все вершины, 
удаленные от текущей на расстояние не более чем в 3 вершины). Он может пере- 
мещаться по ребрам между смежными вершинами. АИ также может метить текущую 
вершину меткой (искусственным ориентиром) из некоторого множества меток. При 
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этом он не может менять метку, которую сам установил. АИ передает АС разметку 
наблюдаемой им локальной окрестности и имя установленной им метки. АС передает 
АИ последовательность меток вершин, описывающую путь по графу. 

Требуется разработать алгоритм перемещений АИ по графу и разметки прой- 
денных вершин, который позволяет восстановить граф. Причем, полученная разметка 
должна позволить АТ, наблюдающему 2-окрестность текущей вершины, осуществ- 
лять навигацию по графу. 

К настоящему времени известно довольно много методов восстановления гра- 
фов [8]. Однако эти методы, как правило, предполагают разметку всех вершин графа 
одной и той же меткой, что неприемлемо для последующей навигации. Тривиаль- 
ным методом решения поставленной задачи является восстановление графа с размет- 
кой каждой его вершины уникальной меткой. В работе предложен алгоритм, в 
котором на основе анализа структуры графа уменьшается число различных меток. 


Основные определения 


Неопределяемые понятия общеизвестны и их можно найти в [9]. 
Помеченным графом назовем конечный простой связный неориентированный 


и =и, 
Е -— множество ребер (т.е. неупорядоченных пар вершин), М -— множество меток, 
и:/ >> М - сюръективная функция разметки вершин. Путем в графе С назовем 


граф с помеченными вершинами С = (У,Е ‚М, и), где Г — множество вершин, 


последовательность вершин р=е,...е, такую, что (2,,5..)Е Е, 1=1....К-1. Число 
КЕМ назовем длиной пути р. Кратчайший путь из вершины © в вершину й 
называется расстоянием между этими вершинами. Меткой и(р) пуги р назовем 
слово "= и(е; у и(®,) в алфавите меток М . Будем говорить, что слово м’ опреде- 


ляется вершиной 2. Длину слова и’ будем обозначать через 4 (и). Начальный отрезок 
или префикс длины [ слова и будем обозначать через рге (и). Конечный отрезок или 


суффикс длины / слова и’ будем обозначать через зи, (и). Инверсией слова ж= 
= и(е; )... (=) назовем слово и’ = и(<,)... (<). Множество [, всех слов ие М*, 
определяемых вершиной © ЕЙ ‚ будем называть языком этой вершины. Граф С будем 
называть приведенным, если для любых вершин 2,й ЕТ из & = 1 следует Г, * [.,. 

Определим на М” частичную операцию ° композиции слов. Пусть а,БЕ М, 
"УЕ М”, тогда иа о ау = мау и уа об» не определено, если а*Ь. 

Введем операцию *:ГхМ* -> 2’ соотношением: для любой вершины 2 ЕГ и 
любого слова \е М” через е*и’ обозначим множество всех вершин йеГ таких, 
что существует путь р, соединяющий вершины © ий, и и( р)= %. Ясно, что если 
слово ие [,, то |= * и >0и |= * и =0 в противном случае. 

Под К-окрестностью р” вершины © ЕТ будем понимать множество всех вер- 
шин, находящихся от © на расстоянии не превосходящем АеМ№. Число К назовем 
размером окрестности Е. „Таким образом, имеем: 

ГО = {8}, ГО =Г ой (в,№)е Е}, Г® =Г® 25 [31 (в,й) Е Ел(в,5) Е Е}} 


ИТ.Д. 
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АИ, находясь в вершине © ЕЙ ‚ наблюдает метки всех вершин из Г } для неко- 


торого КЕМ. Основываясь на анализе «увиденного», агент принимает решение о 
перемещении в одну из смежных вершин. Будем считать, что для перемещения из 
вершины © в смежную ей вершину й АИ должен наблюдать Й и отличать ее от 


всех вершин из Г }. Тогда для перемещений по графу АИ должен отличать вершины 


из 2-окрестности текущей вершины от других наблюдаемых им вершин. АИ может 
либо произвольно блуждать по графу, либо следовать по заданному пути из текущей 
вершины. АИ имеет следующие возможности по временному или постоянному из- 
менению разметки вершин. Он может пометить непомеченную вершину меткой из 
множества М. Он также может устанавливать и подбирать в текущей вершине пере- 
носные маркеры (т.н. камни). 

В качестве меры сложности агента будем рассматривать размер наблюдаемой 
им окрестности текущей вершины. Через АХ обозначим агента, который наблюдает 
К-окрестность текущей вершины. Заметим, что А2 является простейшим агентом, 
так как агент А1 не может осуществлять целенаправленное перемещение. 


Детерминированная разметка вершин 


Обоснуем выбор специальной разметки вершин графа, позволяющей агенту А2 
осуществлять навигацию. 
Функцию разметки и:Г —>М будем называть детерминированной или Д-раз- 


меткой, если для любой вершины © ЕТ и любых вершин 5, е Г) из 5 =[ следует 


и($)= и(е). Помеченный граф С’ с детерминированной функцией разметки будем 
называть детерминированным или Д-графом. 

Рассмотрим свойства Д-графов. 

Лемма 1. Помеченный граф С’ является Д-графом тогда и только тогда, когда 


для любой вершины © ЕТ илюбого слова \е М" выполняется 


ИЕ 1, если ме Гь, 


(0 


0, в противном случае. 


Доказательство. Действительно, для всех слов длины | и 2 равенство (1) 
очевидно, а любое слово длины больше 2 единственным образом записывается в 
виде композиции своих двухбуквенных подслов. С другой стороны, из того, что для 


любой вершины © ЕТ и любого слова "ее М” выполняется | 2 * и <1 следует, что в 
го нет одинаково помеченных вершин. Лемма доказана. 


Таким образом, Д-граф определяется или через локальные свойства его вер- 
шин, или через нелокальное свойство множества всех путей, определяемых каждой 
из вершин. 

Лемма 2. Для любых различных вершин &,й ЕТ и любого слова ме Г, “Г, 
расстояние между вершинами © *у? и й*у не меньше 4. 

Доказательство. Пусть \=х,...х,, где хеЕМ, 1<1<_. Предположим, что 
расстояние между вершинами 5=©*и или 1=й*и меньше 4. Пусть это расстояние 
равно 1, т.е. $5 =2*х,...х, ЕЙ жх,...х, = Тогда в окрестности ге) окажутся две различ- 


ные вершины с одной и той же меткой х,_|, что невозможно по определению Д-графа. 
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Следовательно, 2 *х,...х, | =Й*х,...х, |. По индукции © = й, что невозможно. Пусть 
расстояние между вершинами 5 и Г! равно 2, то есть (5,6) Е. Тогда в окрестности 
г@) находится вершина { с меткой и(у)= м(5), что невозможно по определению Д- 


графа. Пусть расстояние между вершинами $ и { равно 3, то есть существует вершина 
ЧЕТ такая, что путь 54 является кратчайшим путем из 5 в #. Тогда 5,Ёе Ге) и 


и(5) = и(), что невозможно по определению Д-графа. Лемма доказана. 

Одной из центральных проблем, возникающих при навигации МА, является 
проблема самостоятельного определения агентом своего положения в среде (задача 
самолокализации агента) [2], [4]. В [10], [11 предложено решение задачи само- 
локализации для приведенных Д-графов. Следующее утверждение показывает, что 
на вершинах любого конечного связного простого неорграфа может быть построена 
такая Д-разметка, что полученный в результате Д-граф является приведенным, т.е. 
для него разрешима задача самолокализации. 

Лемма 3. Если в Д-графе С существует вершина с уникальной меткой, то С 
является приведенным графом. 

Доказательство. Будем говорить, что вершины ©,ЙеЕТ неотличимы, если 
Г, = Г,. Ясно, что отношение неотличимости является эквивалентностью на множе- 
стве Г. Пусть В, В’ — некоторые классы неотличимости вершин и ©ЕВ. Пусть 


з*\Е В’. Покажем, что | В > |В' . Если йе В, то из неотличимости © и й следует, 
что Ажуе В’. По определению Д-графа й*и=* 2 *у при А =. Поэтому | В < |В'. 
Обозначим ©'=е*у и й'=йжу. Из очевидного неравенства й'*\' #е'*уи’' сле- 
дует |в" < [В]. Таким образом, если некоторый класс неотличимости одноэлементен, 


то и все классы неотличимости одноэлементны. Следовательно, Д-граф С’ является 
приведенным. Лемма доказана. 

Таким образом, если пометить произвольную вершину произвольного Д-графа 
уникальной меткой, то получим приведенный Д-граф. 

Теорема 1. Агент АХ может осуществлять навигацию на Д-графе с п>3 тогда 
и только тогда, когда А>2. 

Доказательство. Покажем, что агент А2, находящийся в вершине = Д-графа С, 


получив от АС слово уе [,,, может переместиться из нее в вершину й=е*у. Пусть 
а (и)= 2. Тогда, по определению Д-графа, в го находится единственная вершина с 
меткой заЁ (и) и этой вершиной является вершина й. А2 «видит», что эта вершина 
смежная вершине © и может переместиться в нее. Пусть 4(и)> 2. Тогда слово и 
единственным образом записывается в виде композиции и су», о...о и) двухбуквен- 
ных подслов у, 4(и,)= 2, 1<1</. Из вершины © агент А2 переходит в вершину 


2*ИЕ ге) . Из вершины ©*у’ он переходит в вершину 2*\и,. | Е а 


ви > 
(2) 
Наконец, из вершины &*и,, агент переходит в вершину 2*у еГ,,„,, которая и 
является вершиной й. Заметим, что агент А] не может пройти путь хх, так как, на- 
ходясь в вершине с меткой х, ‚ агент не «знает» по какому ребру перейти в вершину с 


меткой х,. Теорема доказана. 
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Таким образом, Д-разметка графа является достаточным условием для того, 
чтобы простейший агент мог осуществлять навигацию. 

Рассмотрим проблему построения Д-разметки на графе. Если С является аци- 
клическим графом, т.е. деревом, то агент А2 может построить на нем Д-разметку, 
если агент «запоминает» метки пройденных путей. Покажем, что существует граф, 
который не может быть Д-размечен агентом А2. Рассмотрим пример на рис. 1. 


А2“< 3 


Рисунок 1 


Пусть агент А2 уже выполнил Д-разметку трех вершин графа. Перейдя в непо- 
меченную вершину, он наблюдает вершину с меткой 3 и вершину без метки. Пред- 
положим, что А2 «запомнил» все установленные им метки. Тогда он не может ис- 
пользовать метки 2 и 3. Так как априори граф не известен А2, то, исходя из дос- 
тупной ему информации, агент пометит текущую вершину меткой 1 и, тем самым, 
нарушит детерминированность разметки. Заметим, что агент АЗ, находясь в той же 
вершине, «увидел» бы, что метку 1 нельзя использовать для ее разметки. Из леммы 2 
следует, что вершины, удаленные друг от друга на расстояние не более чем 3 вер- 
шины, не должны иметь одинаковые метки. Таким образом, справедливо следующее 
утверждение. 

Теорема 2. Для Д-разметки произвольного графа агентом АХ достаточно, 
чтобы А превосходило 2. 


Д-разметка вершин графа коллективом агентов 


Из теоремы 2 следует, что для построения Д-разметки достаточно использовать 
агента АЗ. Построение минимальной Д-разметки на основе только лишь локальной 
информации о вершинах (т.е без знания всего графа) представляется невозможным в 
общем случае. Поэтому будем рассматривать «жадный» алгоритм решения этой за- 
дачи с помощью АЗ. 

В основу предлагаемого в работе метода восстановления графа положен метод 
обхода графа в ширину [12]. При этом для каждой вершины # ЕТ в качестве имени 
используется метка пути в нее из начальной вершины по дереву обхода (этим 
объясняется выбор в пользу метода обхода в ширину: так как путь в любую вершину 
из начальной по дереву обхода имеет кратчайшую длину среди всех таких путей, то 
и длина имени этой вершины также кратчайшая). 

Зададим линейный порядок на множестве М. Без потери общности можно 
предположить, что М < М и, что перед началом работы алгоритма все вершины 
исследуемого графа помечены меткой 0. 
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Для каждой вершины © ЕТ хранятся ее имя пате(®), ее метка и(<), множе- 
ство 4/ (=) смежных с ней вершин и множество [1 (=) меток этих вершин. Для хра- 


нения множества имен вершин, окрестности которых еще не обработаны, использу- 
ется список Т типа ЕТЕО. Для хранения имен всех вершин используется множество \М. 
Первоначально АИ устанавливается в неизвестную ему вершину 5 исследуемого 


графа С’. АИ считывает метки вершин из Гб), корректирует множество доступных для 
Д-разметки меток, метит 5 наименьшей из них и передает АС метку (5). Если требу- 
ется получить приведенный граф, то метка (5) больше не используется. АС вычисляет 
имя пате($) (для начальной вершины пате(5) = и(5)) и добавляет его вТи У”. 

Пусть на 1-ой итерации АИ находится в некоторой уже помеченной им 
вершине 2ЕТ. Для всех вершин с меткой 0 из г” АИ выбирает любую из них, 


например 2, и перемещается в нее. АИ считывает метки вершин из Г“), корректирует 
множество доступных для Д-разметки меток, метит { наименьшей из них и передает 
АС метку /4(Г). АС добавляет (Г) в [1(2) , вычисляет имя пате(г) как конкатенацию 
пате( 2) и(Г) и добавляет его в Т, \М и 4[(=). Далее, АС добавляет пате(®) и и(2) в 


АКГ) и М(Е) соответственно. После этого АИ возвращается в вершину ©. 


Окончив разметку а коллектив агентов приступает к проверке ребер, попе- 
речных дереву обхода. АИ считывает метки всех вершин из р и передает АС мно- 
жество Я”) . Если ше) \ (=) = © ‚то АС передает АИ произвольную метку из 


иг®)\ [1 (=), например метку и(4) вершины 4. АИ переходит в 4 и оставляет в 
ней камень. АС находит в У! имена всех вершин, которые имеют длину больше или 
равную длине иате(=) и оканчиваются на /(4). Затем АС поочередно передает АИ 


метки путей в эти вершины по дереву обхода. АИ перемещается по этим путям до 
тех пор, пока не обнаруживает камень. АИ подбирает камень и переходит в вершину 


&.АС добавляет пате(4), (а), пате(®), и(®) в АК), М(®), АЦа), ШМ(4) соот- 
ветственно. Описанные выше действия выполняются до тех пор, пока в Г) не 
окажутся все вершины из 2-окрестности вершины ©. 


Далее АС пытается извлечь имя вершины из списка Т. Если он пуст, то все 
вершины графа С уже помечены и алгоритм оканчивает работу. В противном случае, 
АС извлекает из Т имя очередной вершины, например й. По именам вершин © и й 


АС вычисляет метку пути из © в й по дереву обхода и передает ее АИ. АИ переме- 


щается по этому пути в вершину Й и приступает к обработке ее 2-окрестности. 
С целью анализа предложенного метода, докажем следующее утверждение. 
Теорема 3. Коллектив из АС и АИ восстанавливает произвольный связный 


неорграф С путем Д-разметки его вершин за время О(и°). 

Доказательство. Покажем, что, по окончании работы алгоритма, у каждой 
вершины © ЕТ в множестве АГ(5) содержатся все смежные © вершины графа С. 
Действительно, вершины из го ‚ смежные © в дереве обхода, попадают в 4/ (=) при 
разметке ее окрестности, а вершины, соединенные с © поперечными дереву обхода 
ребрами, попадают в АГ(5) при обработке поперечных ребер. Таким образом, по 
окончании работы алгоритма полностью восстанавливаются списки смежности для 
всех вершин графа С. 
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Восстановление графа операционной среды мобильного роботи... 


УГ 


Каждая вершина графа С’один раз помещается в очередь Т и один раз извлекается 
из нее. Таким образом, для выполнения алгоритма достаточно О(и) итераций. Для раз- 


(2) > 
метки окрестности Г, текущей вершины & достаточно О(п) шагов. Для отыскания по- 
перечных ребер, соединяющих вершину © с другими вершинами дерева обхода, достато- 


чно О”) шагов: не более О(и) шагов на отыскание поперечных ребер и не более Си) 

шагов на поиск по дереву обхода вершины помеченной камнем. Таким образом, вре- 

менная сложность Д-разметки графа коллективом из АС и АИ ограничена О(п”). 
Теорема доказана. 


Выводы 


В работе решена задача восстановления связного неорграфа мобильным агентом 
пугем детерминированной разметки его вершин. Разработан алгоритм восстановления 
графа агентом, наблюдающим 3-окрестности посещаемых им вершин. Доказана коррек- 
тность алгоритма и найдена оценка его временной сложности. В дальнейшем пред- 
полагается исследовать влияние размера наблюдаемой агентом окрестности и объема 
используемой им памяти на способность агента решить задачу восстановления графа. 
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КЕЗОМЕ 


1.5. Стип5Ку, 5.Г. Зарипоу 

Кесопягиспоп оГ!е Старй оГОрегайпие 
ЕпутгоптетЕ о/ МоБйе Коро! Бу Гемех ГаБейпе 
зирпстетЕ юг Еитйег Маеайоп 


Тре ргоет о{ гобойс ехрюгайоп о этарБ-ПКе орегайп» епутоптепе 1$ с0п81- 
Дегед. Тне ргоет 15: ап чпкпо\й епупоптеп тодееЯ аз Нпие зипр!е соппецщед 
ипанесцеа уецех 1абее4 отарн 15 отуеп, Югишае ап ехр|огаНоп зтаесу Юг Ше гоБо%, 50 
Фав, айег саггуте опё фе асйоп$ зрес!Йед Бу Ше эгажезу, Ше гобо{ Ш Вауе Югте4 а 
гергезещаноп оЁ #з епугоптепе за Ислепе Юг 50[ушс пау1айоп {азКз$ 1.е. а тар. 

Тре аиог$ са| уецех 1аБе]е4 отарН деегииши$Ис Ша уегисез ш пеоВотВоо4 оЁ 
еасв уецех Пауе 41$Ипсе |аБе]5. Тве за Йслепсу оЁ деегииизИс отарН$ Юг зоуше 
паутсаноп фазКз 15 Четопзгафеа. 

Тре ад огз ргорозе ро]упопиа {те ехрогайоп аеогинт Юг соПеснуе оЁ тоБо{- 
ехрогег ап гофбо{-зирегу15ог. КоБо{-ехр|огег 1гауегзез фе отарВ, обзегуез Ше Тоса1 
пеНботвоо4$ оЁ1е уегисе$ ап свапоез Ше епупоптепЕ Бу зе те 1аБе]5 а {Пе уегисе$ 
ш деегиии$Ис таппег. ВоБо{-ехр|огег зеп45$ шогтайоп абоц{ уецех 1аБеПпо 10 гобо{- 
зирегу1вог. КоБо!{-зирегу1вог Югиз а тар оЁ Ше епупоптепЕ Базе оп 1$ шЮгтаноп. 
То зоуе Фе ргоМет оЁ д&етитте \ПНеп Ше гобо{-ехр/огег Ваз гебигпе4 0 а ргемои$1у 
у1з Нед уецех 4игте тар БаПате, 1е амогз изе ропа е тагКег а$ а рай оРехроганоп 
знгаеэу. 


Статья поступила в редакцию 15.06.2012. 
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